<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>外间距margin</title>
    <style>
        /* 去掉body自带的外间距 */
        body {
            margin: 0;
        }
        .fu {
            background-color: rgba(255,255,0,.3);
            /* 让父元素形成BFC结界,首尾子元素的外间距不会超出父元素的范围 */
            overflow: hidden;
        }
        .fu>div {
            width: 100px;
            height: 100px;
            background-color: rgba(0,0,255,0.6);
            border: 2px solid #00f;
            color: #fff;
        }
        /* 相邻兄弟垂直方向的外间距取大值显示,不会叠加 */
        .z1 {
            margin-bottom: 30px;
            margin-top: 50px;
        }
        .z2 {
            margin-top: 50px;
        }
        .z4 {
            margin-bottom: 50px;
        }
        .z3 {
            margin: 10px; /*四个方向都是10*/
            margin: 10px 20px; /* 上下10 左右20 */
            margin: 10px 20px 30px; /* 上10 左右20 下30 */
            margin: 10px 20px 30px 40px;/* 上10 右20 下30 左40 */
            /* 实现块级元素自己的水平居中
            auto:自动将本元素的左右外间距计算成等值 */
            margin: 0 auto;
        }
        span {
            border: 2px solid #f00;
        }
        .s2 {
            /* 行内元素垂直方向的外间距不生效! */
            margin: 30px;
        }
    </style>
</head>
<body>
<span>span1</span><span class="s2">span2</span><span>span3</span>
<!-- .fu>.z*4 -->
<div class="fu">
    <div class="z1">子元素1</div>
    <div class="z2">子元素2</div>
    <div class="z3">子元素3</div>
    <div class="z4">子元素4</div>
</div>
</body>
</html>